1. 7주차 결과보고서

|  |
| --- |
| * 1. - Even Parity bit Generator & Checker   2. - Odd Parity bit Generator & Checker   - 2 bit binary Comparator  - 결과 검토 |

**20141196 김성희**

1. 1. Even Parity bit Generator & Checker
   1. **1-1. Even Parity bit Generator**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| - 원본 데이터의 1의 개수가 홀수일 때, parity bit 1을 추가한다. 즉 (원본데이터 + parity bit)의 1의 개수가 짝수가 되게 끔 bit를 추가한다.  - 구현은 입력 4bit로 해보자.  **< Truth Table >**   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **A** | **B** | **C** | **D** | **Pb** | | **0** | **0** | **0** | **0** | **0** | | **0** | **0** | **0** | **1** | **1** | | **0** | **0** | **1** | **0** | **1** | | **0** | **0** | **1** | **1** | **0** | | **0** | **1** | **0** | **0** | **1** | | **0** | **1** | **0** | **1** | **0** | | **0** | **1** | **1** | **0** | **0** | | **0** | **1** | **1** | **1** | **1** | | **1** | **0** | **0** | **0** | **1** | | **1** | **0** | **0** | **1** | **0** | | **1** | **0** | **1** | **0** | **0** | | **1** | **0** | **1** | **1** | **1** | | **1** | **1** | **0** | **0** | **0** | | **1** | **1** | **0** | **1** | **1** | | **1** | **1** | **1** | **0** | **1** | | **1** | **1** | **1** | **1** | **0** |   **< Karnaugh Map > for Pb**   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **AB**  **CD** | **00** | **01** | **11** | **10** | | **00** | **0** | **1** | **0** | **1** | | **01** | **1** | **0** | **1** | **0** | | **11** | **0** | **1** | **0** | **1** | | **10** | **1** | **0** | **1** | **0** |   Pb = A’B’C’D+A’B’CD’+A’BC’D’+A’BCD+ABC’D+ABCD’+AB’C’D’+AB’CD  = A’B’ (C’D+CD’)+AB(C’D+CD’)+A’B(C’D’+CD)+AB’ (C’D’+CD)  = (A’B+AB’)(C’D’+CD)+(A’B’+AB)(C’D+CD’)  = (A’B+AB’)ⓧ(C’D+CD’)  = **AⓧBⓧCⓧD**  **< Code >**    - 왼쪽은 Design source, 오른쪽은 Simulation source다.  **< Simulation >**    - A,B,C,D 중에서 1인 입력 값이 홀수 개인 경우 Pb가 1이 되는 것을 볼 수 있다.  **< Schematic >**    **< FPGA >**  -Design Sources경로에 code 짜기 -> Run Synthesis & Run Implementation -> Constraints경로에 .xdc 파일 추가하기 -> Open Implemented Design 클릭 후 Constraints Wizard 클릭(Define Target, .xdc파일 타겟 설정) -> Window 탭에서 I/O ports 클릭 -> 원하는 pin 선택 및 LVCMOS18(I/O Std) 선택 -> 저장 후 .xdc reload(아래 그림처럼 코드가 자동으로 짜서 나온다.) -> Generate Bitstream 클릭(Synthesis, Implementation도 자동으로 실행) 후에 Open Hardware Manager 클릭 -> Open Target 클릭 후 Auto Connect 클릭 -> Program Device 클릭 -> FPGA에 업로드 끝  <- 입력, 출력 pin 설정  - UP switch, RIGHT switch, DOWN switch, LEFT switch 각각 A, B, C, D 입력과 맵핑  - LED1은 Pb에 맵핑  - 각 switch를 홀수 개만큼 누르면 LED1에 불이 켜진다. |

* 1. **1-2. Even Parity bit Checker**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| - (원본 데이터 + parity bit)의 1의 개수가 홀수면 1, 짝수면 0을 출력하는 회로  - 구현은 입력 5bit(3bit+1bit)로 해보자.  **< Truth Table >**   |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | | **A** | **B** | **C** | **D** | **Pb** | **Ch** | | **0** | **0** | **0** | **0** | **0** | **0** | | **0** | **0** | **0** | **0** | **1** | **1** | | **0** | **0** | **0** | **1** | **0** | **1** | | **0** | **0** | **0** | **1** | **1** | **0** | | **0** | **0** | **1** | **0** | **0** | **1** | | **0** | **0** | **1** | **0** | **1** | **0** | | **0** | **0** | **1** | **1** | **0** | **0** | | **0** | **0** | **1** | **1** | **1** | **1** | | **0** | **1** | **0** | **0** | **0** | **1** | | **0** | **1** | **0** | **0** | **1** | **0** | | **0** | **1** | **0** | **1** | **0** | **0** | | **0** | **1** | **0** | **1** | **1** | **1** | | **0** | **1** | **1** | **0** | **0** | **0** | | **0** | **1** | **1** | **0** | **1** | **1** | | **0** | **1** | **1** | **1** | **0** | **1** | | **0** | **1** | **1** | **1** | **1** | **0** | | **1** | **0** | **0** | **0** | **0** | **1** | | **1** | **0** | **0** | **0** | **1** | **0** | | **1** | **0** | **0** | **1** | **0** | **0** | | **1** | **0** | **0** | **1** | **1** | **1** | | **1** | **0** | **1** | **0** | **0** | **0** | | **1** | **0** | **1** | **0** | **1** | **1** | | **1** | **0** | **1** | **1** | **0** | **1** | | **1** | **0** | **1** | **1** | **1** | **0** | | **1** | **1** | **0** | **0** | **0** | **0** | | **1** | **1** | **0** | **0** | **1** | **1** | | **1** | **1** | **0** | **1** | **0** | **0** | | **1** | **1** | **0** | **1** | **1** | **0** | | **1** | **1** | **1** | **0** | **0** | **1** | | **1** | **1** | **1** | **0** | **1** | **0** | | **1** | **1** | **1** | **1** | **0** | **0** | | **1** | **1** | **1** | **1** | **1** | **1** |   **< Karnaugh Map > for Ch**  A = 0   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **BC**  **D Pb** | **00** | **01** | **11** | **10** | | **00** | **0** | **1** | **0** | **1** | | **01** | **1** | **0** | **1** | **0** | | **11** | **0** | **1** | **0** | **1** | | **10** | **1** | **0** | **1** | **0** |   A = 1   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **BC**  **D Pb** | **00** | **01** | **11** | **10** | | **00** | **1** | **0** | **1** | **0** | | **01** | **0** | **1** | **0** | **1** | | **11** | **1** | **0** | **1** | **0** | | **10** | **0** | **1** | **0** | **1** |   Ch = A’(B’C’D’Pb+B’C’DPb’+B’C’D’Pb’+B’CDPb+BCD’Pb+BCDPb’+BC’D’Pb’+BC’DPb)  + A(B’C’D’Pb’+B’C’DPb+B’C’D’Pb+B’CDPb’+BCD’Pb’+BCDPb+BC’D’Pb+BC’DPb’)  = A’(B’C’(D’Pb+DPb’)+BC(D’Pb+DPb’)+B’C(D’Pb’+DPb)+BC’(D’Pb’+DPb))  + A(B’C’(D’Pb’+DPb)+BC(D’Pb’+DPb)+B’C(D’Pb+DPb’)+BC’(D’Pb+DPb’))  = A’((B’C+BC’)(D’Pb’+DPb)+(B’C’+BC)(D’Pb+DPb’))  + A((B’C+BC’)(D’Pb+DPb’)+(B’C’+BC)(D’Pb’+DPb))  = A’((B’C+BC’)ⓧ(D’Pb+DPb’))  + A((B’C+BC’)ⓧ(D’Pb+DPb’))’  = A’(BⓧCⓧDⓧPb) + A(BⓧCⓧDⓧPb)’  = **AⓧBⓧCⓧDⓧPb**  **< Code >**    - 왼쪽은 Design source, 오른쪽은 Simulation source다.  **< Simulation >**    - A,B,C,D,Pb 중에서 1인 입력 값이 홀수 개인 경우Ch가 1이 되는 것을 볼 수 있다.  **< Schematic >**    **< FPGA >**  -Design Sources경로에 code 짜기 -> Run Synthesis & Run Implementation -> Constraints경로에 .xdc 파일 추가하기 -> Open Implemented Design 클릭 후 Constraints Wizard 클릭(Define Target, .xdc파일 타겟 설정) -> Window 탭에서 I/O ports 클릭 -> 원하는 pin 선택 및 LVCMOS18(I/O Std) 선택 -> 저장 후 .xdc reload(아래 그림처럼 코드가 자동으로 짜서 나온다.) -> Generate Bitstream 클릭(Synthesis, Implementation도 자동으로 실행) 후에 Open Hardware Manager 클릭 -> Open Target 클릭 후 Auto Connect 클릭 -> Program Device 클릭 -> FPGA에 업로드 끝  <- 입력, 출력 pin 설정  - UP switch, RIGHT switch, DOWN switch, LEFT switch, MID switch 각각 A, B, C, D, Pb 입력과 맵핑  - LED1은 Ch에 맵핑  - 각 switch를 홀수 개만큼 누르면 LED1에 불이 켜진다. |

1. 2. Odd Parity bit Generator & Checker
   1. **2-1. Odd Parity bit Generator**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| - 원본 데이터의 1의 개수가 짝수일 때, parity bit 1을 추가한다. 즉 (원본데이터 + parity bit)의 1의 개수가 홀수가 되게 끔 bit를 추가한다.  - 구현은 입력 4bit로 해보자.  **< Truth Table >**   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **A** | **B** | **C** | **D** | **Pb** | | **0** | **0** | **0** | **0** | **1** | | **0** | **0** | **0** | **1** | **0** | | **0** | **0** | **1** | **0** | **0** | | **0** | **0** | **1** | **1** | **1** | | **0** | **1** | **0** | **0** | **0** | | **0** | **1** | **0** | **1** | **1** | | **0** | **1** | **1** | **0** | **1** | | **0** | **1** | **1** | **1** | **0** | | **1** | **0** | **0** | **0** | **0** | | **1** | **0** | **0** | **1** | **1** | | **1** | **0** | **1** | **0** | **1** | | **1** | **0** | **1** | **1** | **0** | | **1** | **1** | **0** | **0** | **1** | | **1** | **1** | **0** | **1** | **0** | | **1** | **1** | **1** | **0** | **0** | | **1** | **1** | **1** | **1** | **1** |   **< Karnaugh Map > for Pb**   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **AB**  **CD** | **00** | **01** | **11** | **10** | | **00** | **1** | **0** | **1** | **0** | | **01** | **0** | **1** | **0** | **1** | | **11** | **1** | **0** | **1** | **0** | | **10** | **0** | **1** | **0** | **1** |   Pb = A’B’C’D’+A’B’CD+A’BC’D+A’BCD’+ABC’D’+ABCD+AB’C’D+AB’CD’  = (A’B’+AB)(C’D’+CD)+ (A’B+AB’)(C’D+CD’)  = (**AⓧBⓧCⓧD)**’  **< Code >**    - 왼쪽은 Design source, 오른쪽은 Simulation source다.  **< Simulation >**    - A,B,C,D 중에서 1인 입력 값이 짝수(또는0)개인 경우 Pb가 1이 되는 것을 볼 수 있다.  **< Schematic >**    **< FPGA >**  -Design Sources경로에 code 짜기 -> Run Synthesis & Run Implementation -> Constraints경로에 .xdc 파일 추가하기 -> Open Implemented Design 클릭 후 Constraints Wizard 클릭(Define Target, .xdc파일 타겟 설정) -> Window 탭에서 I/O ports 클릭 -> 원하는 pin 선택 및 LVCMOS18(I/O Std) 선택 -> 저장 후 .xdc reload(아래 그림처럼 코드가 자동으로 짜서 나온다.) -> Generate Bitstream 클릭(Synthesis, Implementation도 자동으로 실행) 후에 Open Hardware Manager 클릭 -> Open Target 클릭 후 Auto Connect 클릭 -> Program Device 클릭 -> FPGA에 업로드 끝  <- 입력, 출력 pin 설정  - UP switch, RIGHT switch, DOWN switch, LEFT switch각각 A, B, C, D 입력과 맵핑  - LED1은 Pb에 맵핑  - 각 switch를 짝수 개만큼 누르면 LED1에 불이 켜진다. |

* 1. **2-2. Odd Parity bit Checker**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| - (원본 데이터 + parity bit)의 1의 개수 짝수 개면 1을, 홀수 개면 0을 출력하는 회로.  - 구현은 입력 4bit(3bit+1bit)로 해보자.  **< Truth Table >**   |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | | **A** | **B** | **C** | **D** | **Pb** | **Ch** | | **0** | **0** | **0** | **0** | **0** | **1** | | **0** | **0** | **0** | **0** | **1** | **0** | | **0** | **0** | **0** | **1** | **0** | **0** | | **0** | **0** | **0** | **1** | **1** | **1** | | **0** | **0** | **1** | **0** | **0** | **0** | | **0** | **0** | **1** | **0** | **1** | **1** | | **0** | **0** | **1** | **1** | **0** | **1** | | **0** | **0** | **1** | **1** | **1** | **0** | | **0** | **1** | **0** | **0** | **0** | **0** | | **0** | **1** | **0** | **0** | **1** | **1** | | **0** | **1** | **0** | **1** | **0** | **1** | | **0** | **1** | **0** | **1** | **1** | **0** | | **0** | **1** | **1** | **0** | **0** | **1** | | **0** | **1** | **1** | **0** | **1** | **0** | | **0** | **1** | **1** | **1** | **0** | **0** | | **0** | **1** | **1** | **1** | **1** | **1** | | **1** | **0** | **0** | **0** | **0** | **0** | | **1** | **0** | **0** | **0** | **1** | **1** | | **1** | **0** | **0** | **1** | **0** | **1** | | **1** | **0** | **0** | **1** | **1** | **0** | | **1** | **0** | **1** | **0** | **0** | **1** | | **1** | **0** | **1** | **0** | **1** | **0** | | **1** | **0** | **1** | **1** | **0** | **0** | | **1** | **0** | **1** | **1** | **1** | **1** | | **1** | **1** | **0** | **0** | **0** | **1** | | **1** | **1** | **0** | **0** | **1** | **0** | | **1** | **1** | **0** | **1** | **0** | **0** | | **1** | **1** | **0** | **1** | **1** | **1** | | **1** | **1** | **1** | **0** | **0** | **0** | | **1** | **1** | **1** | **0** | **1** | **1** | | **1** | **1** | **1** | **1** | **0** | **1** | | **1** | **1** | **1** | **1** | **1** | **0** |   **< Karnaugh Map > for Ch**  A = 0   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **BC**  **D Pb** | **00** | **01** | **11** | **10** | | **00** | **1** | **0** | **1** | **0** | | **01** | **0** | **1** | **0** | **1** | | **11** | **1** | **0** | **1** | **0** | | **10** | **0** | **1** | **0** | **1** |   A = 1   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **BC**  **D Pb** | **00** | **01** | **11** | **10** | | **00** | **0** | **1** | **0** | **1** | | **01** | **1** | **0** | **1** | **0** | | **11** | **0** | **1** | **0** | **1** | | **10** | **1** | **0** | **1** | **0** |   Ch = A’(B’C’D’Pb’+B’C’DPb+B’C’D’Pb+B’CDPb’+BCD’Pb’+BCDPb+BC’D’Pb+BC’DPb’)  + A(B’C’D’Pb+B’C’DPb’+B’C’D’Pb’+B’CDPb+BCD’Pb+BCDPb’+BC’D’Pb’+BC’DPb)  = A’(B’C’(D’Pb’+DPb)+BC(D’Pb’+DPb)+B’C(D’Pb+DPb’)+BC’(D’Pb+DPb’))  + A(B’C’(D’Pb+DPb’)+BC(D’Pb+DPb’)+B’C(D’Pb’+DPb)+BC’(D’Pb’+DPb))  = A’((B’C’+BC)(D’Pb’+DPb)+(B’C+BC’)(D’Pb+DPb’))  + A((B’C’+BC)(D’Pb+DPb’)+(B’C+BC’)(D’Pb’+DPb))  = A’((B’C+BC’)ⓧ(D’Pb+DPb’))’  + A((B’C+BC’)ⓧ(D’Pb+DPb’))  = A’(BⓧCⓧDⓧPb)’ + A(BⓧCⓧDⓧPb)  = (**AⓧBⓧCⓧDⓧPb)’**  **< Code >**    - 왼쪽은 Design source, 오른쪽은 Simulation source다.  **< Simulation >**    - A,B,C,D,Pb 중에서 1인 입력 값이 짝수(또는 0)개인 경우 Ch가 1이 되는 것을 볼 수 있다.  **< Schematic >**    **< FPGA >**  -Design Sources경로에 code 짜기 -> Run Synthesis & Run Implementation -> Constraints경로에 .xdc 파일 추가하기 -> Open Implemented Design 클릭 후 Constraints Wizard 클릭(Define Target, .xdc파일 타겟 설정) -> Window 탭에서 I/O ports 클릭 -> 원하는 pin 선택 및 LVCMOS18(I/O Std) 선택 -> 저장 후 .xdc reload(아래 그림처럼 코드가 자동으로 짜서 나온다.) -> Generate Bitstream 클릭(Synthesis, Implementation도 자동으로 실행) 후에 Open Hardware Manager 클릭 -> Open Target 클릭 후 Auto Connect 클릭 -> Program Device 클릭 -> FPGA에 업로드 끝  <- 입력, 출력 pin 설정  - UP switch, RIGHT switch, DOWN switch, MID switch각각 A, B, C, D, Pb 입력과 맵핑  - LED1은 Ch에 맵핑  - 각 switch를 짝수 개만큼 누르면 LED1에 불이 켜진다. |

1. 3. 2-bit binary Comparator

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| - 2bit 입력 2개의 크기를 비교하는 회로  **- (**A1 A2), (B1 B2) 2bit 입력 2개와 F1, F2, F3 1bit 출력 3개  **< Truth Table >**   |  |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | --- | | **A1** | **A2** | **B1** | **B2** | **F1(A>B)** | **F2(A=B)** | **F3(A<B)** | | **0** | **0** | **0** | **0** | **0** | **1** | **0** | | **0** | **0** | **0** | **1** | **0** | **0** | **1** | | **0** | **0** | **1** | **0** | **0** | **0** | **1** | | **0** | **0** | **1** | **1** | **0** | **0** | **1** | | **0** | **1** | **0** | **0** | **1** | **0** | **0** | | **0** | **1** | **0** | **1** | **0** | **1** | **0** | | **0** | **1** | **1** | **0** | **0** | **0** | **1** | | **0** | **1** | **1** | **1** | **0** | **0** | **1** | | **1** | **0** | **0** | **0** | **1** | **0** | **0** | | **1** | **0** | **0** | **1** | **1** | **0** | **0** | | **1** | **0** | **1** | **0** | **0** | **1** | **0** | | **1** | **0** | **1** | **1** | **0** | **0** | **1** | | **1** | **1** | **0** | **0** | **1** | **0** | **0** | | **1** | **1** | **0** | **1** | **1** | **0** | **0** | | **1** | **1** | **1** | **0** | **1** | **0** | **0** | | **1** | **1** | **1** | **1** | **0** | **1** | **0** |   **< Karnaugh Map >**  F1(A>B)   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **A1 A2**  **B1 B2** | **00** | **01** | **11** | **10** | | **00** | **0** | **1** | **1** | **1** | | **01** | **0** | **0** | **1** | **1** | | **11** | **0** | **0** | **0** | **0** | | **10** | **0** | **0** | **1** | **0** |   F1 = A2B1’B2’+A1B1’+A1A2B2’  = A2B2’(A1+ B1’)+A1B1’  F2(A=B)   |  |  |  |  |  | | --- | --- | --- | --- | --- | | **A1 A2**  **B1 B2** | **00** | **01** | **11** | **10** | | **00** | **1** | **0** | **0** | **0** | | **01** | **0** | **1** | **0** | **0** | | **11** | **0** | **0** | **1** | **0** | | **10** | **0** | **0** | **0** | **1** |   F2 = A1’A2’B1’B2’+A1’A2B1’B2+A1A2B1B2+A1A2’B1B2’  = A1’B1’(A2’B2’+A2B2)+A1B1(A2’B2’+A2B2)  = (A1’B1’+A1B1)(A2’B2’+A2B2)  = (A1ⓧB1)’(A2ⓧB2)’  F3(A<B)   |  |  |  |  |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | | **A1 A2**  **B1 B2** | **00** | **01** | **11** | **10** |  |  |  |  |  | | **00** | **0** | **0** | **0** | **0** |  |  |  |  |  | | **01** | **1** | **0** | **0** | **0** |  |  |  |  |  | | **11** | **1** | **1** | **0** | **1** |  |  |  |  |  | | **10** | **1** | **1** | **0** | **0** |  |  |  |  |  |   F3 = A1’A2’B2+A2’B1B2+A1’B1  = A2’B2(A1’+B1)+A1’B1  **< Code >**    - 왼쪽은 Design source, 오른쪽은 Simulation source다.  **< Simulation >**    - A = (A1 A2), B = (B1 B2)일 때 F1은 A>B, F2는 A=B, F3은 A<B일 때, 1의 값을 가진다.  **< Schematic >**    **< FPGA >**  -Design Sources경로에 code 짜기 -> Run Synthesis & Run Implementation -> Constraints경로에 .xdc 파일 추가하기 -> Open Implemented Design 클릭 후 Constraints Wizard 클릭(Define Target, .xdc파일 타겟 설정) -> Window 탭에서 I/O ports 클릭 -> 원하는 pin 선택 및 LVCMOS18(I/O Std) 선택 -> 저장 후 .xdc reload(아래 그림처럼 코드가 자동으로 짜서 나온다.) -> Generate Bitstream 클릭(Synthesis, Implementation도 자동으로 실행) 후에 Open Hardware Manager 클릭 -> Open Target 클릭 후 Auto Connect 클릭 -> Program Device 클릭 -> FPGA에 업로드 끝  <- 입력, 출력 pin 설정  - UP switch, RIGHT switch, LEFT switch, DOWN switch 각각 A1, A2, B1, B2 입력과 맵핑  - LED1, LED2, LED3 각각 F1, F2, F3에 맵핑  - 위simualtion에 맞춰서 switch를 누르면 LED1, LED2, LED3을 끄고 켤 수 있다. |

1. 4. 결과 검토 및 논의 사항

- 2-bit binary comparator에 2input gate가 아닌 3input gate를 사용 가능했다면 훨씬 보기 좋고 효율적인 shcematic을 만들 수 있었을 것이다.

1. 5. 기타 이론

- 입력 변수가 5개인 Karnaugh Map은 1-2와 2-2 처럼 표를 두 개 그리고 3차원적으로 상상해서 표시하면 된다. 예를 들어 A=0 B’C’D’E’와 A=1 B’C’D’E’가 둘 다 1인경우 아래 그림처럼 각각 위 아래로 z축을 추가하여 묶으면 된다.

![](data:image/png;base64,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)

1. 6. FPGA pin No.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **LED1** | **LED2** | **LED3** | **LED4** | **LED5** |
| F15 | F13 | F14 | F16 | F17 |
| **UP switch** | **RIGHT switch** | **DOWN switch** | **LEFT switch** | **MID switch** |
| E21 | G22 | F21 | D21 | G21 |